草庐IT

JavaScript - 覆盖或阻止执行

全部标签

ruby - 在 String 子类上覆盖 =~ 方法会产生不一致

我为String的子类覆盖了=~方法:classMyString重写的方法在某些情况下被正确调用:r=/abc/s=~r#=>"Overriddenmethod."s.send(:=~,r)#=>"Overriddenmethod."s.send(:=~,/abc/)#=>"Overriddenmethod."而在其他情况下它被绕过,而是调用String#=~:s=~/abc/#=>0s=~(/abc/)#=>0我可以在Ruby1.8.7、2.1.0上重现这些结果。有人知道为什么会这样吗?是错误吗? 最佳答案 在String#=~的

ruby-on-rails - Rails 查询执行导致数据库峰值

我的Rails应用程序出现问题,一些随机查询需要大约5秒或更长时间才能完成。大多数时候,查询非常简单(select*fromxwhereid=?),而且字段甚至也被编入索引。这里有一些关于设置的更多信息:反向nginx代理背后的Puma3.5.04个worker,每个worker最少4个,最多8个线程。Rubyv2.2.3,Railsv4.2.4PostgreSQL9.4数据库线程池设置为最多60个连接监控应用8GBRAM、4个CPU、SSD。我在查看Appsignal中的查询性能时发现了这一点。我注意到大多数查询在几毫秒内完成,然后时不时地,仍然在同一个请求中,有多个查询需要5秒以上

ruby - Thor 可执行文件 - 忽略任务名称

雷神维基页面,MakinganExectable,向您展示了如何创建一个看起来像这样的thor支持的CLI命令:庆典./mythorcommandfoo这需要您将thor任务foo作为第一个参数传递。我还可以使用thor的default_method运行不带任何参数的thor可执行文件:庆典./神话命令但是,我想传入一个可变字符串作为第一个参数:庆典./mythorcommand"somevalue"这不起作用,因为thor命令期望第一个参数是任务名称。有没有办法忽略任务名称并将第一个参数发送到默认方法?如果这个功能不存在,我认为添加一个将所有命令行参数传递到一个任务/方法中的方法会非

ruby-on-rails - 覆盖由同一模块中的类方法定义的 ActiveSupport::Concern 模块中的方法

我有一个ActiveSupport::Concern模块,大致如下所示:moduleMyModelmoduleAcceptanceextendActiveSupport::Concernincludeddoenumstatus:[:declined,:accepted]enddefdeclined!self.status=:declined#someextralogicself.save!enddefaccepted!self.status=:accepted#someextralogicself.save!endendend这只会被包含到ActiveRecord类中,因此使用enum

ruby - 我可以覆盖任务 :environment in test_helper. rb 来测试 rake 任务吗?

我在Rakefile中有一系列rake任务,我想将其作为我的规范等的一部分进行测试。每个任务都以以下形式定义:task:do_somthing=>:environmentdo#Dosomethingwiththedatabasehereend:environment任务设置ActiveRecord/DataMapper数据库连接和类。我没有将其用作Rails的一部分,但我有一系列测试,我喜欢将其作为BDD的一部分运行。此片段说明了我如何尝试测试rake任务。defsetup@rake=Rake::Application.newRake.application=@rakeloadFile

ruby - ruby代码是如何执行的

我最近开始学习Ruby。我知道Ruby是一种解释型语言(尽管“每种”语言都是因为它被CPU解释为机器代码)。但是ruby​​解释器如何将用Ruby编写的代码转换为机器码呢?我读过解释器不读取源代码,而是字节码,但是我永远不必像在Java中那样进行编译。那么,这是Ruby为您做的另一件事吗?如果是,它会在运行时生成字节码吗?因为您永远不会像在Java中那样获得.class文件。最重要的是,我阅读了关于即时编译器的所有内容,这些编译器显然对字节代码做了一些事情,因此它运行得更快。如果是上述情况,解释器是否首先扫描所有源代码,将其转换为字节码,然后在运行时使用JIT再次编译?最后,我不是在寻

ruby - 为什么我们不能覆盖 `||` 和 `&&` ?

DavidA.Black在他的书中说:[T]heconditionalassignmentoperator||=,aswellasitsrarelyspottedcousin&&=,bothofwhichprovidethesamekindofshortcutasthepseudooperatormethodsbutarebasedonoperators,namely||and&&,whichyoucan’toverride.为什么他特别提到我们不能覆盖||和&&? 最佳答案 与对象上的一些其他运算符不同,对象的行为在逻辑上可以取决

ruby-on-rails - 如何覆盖 'as_json' 或 'to_json' 方法,以便 'respond_to' 不包含指定信息?

我正在使用RubyonRails3,我想覆盖(可能在模型文件中)as_json或to_json方法以respond_to不包含某些信息的HTTP请求。在我的帐户模型中我有defas_json(options={})super(:except=>[:password])end在我的Controller中我有format.json{render:json=>@account,:status=>200}例如,当我向/account/1.json发出请求时,我还返回了出于安全原因我不想要的密码属性。那么,如何防止包含指定信息?我能做到,而且行得通format.json{render:json=

ruby-on-rails - 覆盖 Rails ActiveRecord 销毁行为的最佳方法是什么?

我有一个应用程序,我想在其中覆盖我的许多模型的销毁行为。用例是用户可能有删除特定记录的合法需求,但实际上从数据库中删除该行会破坏影响其他相关模型的参照完整性。例如,系统的用户可能想要删除不再与之有业务往来的客户,但需要维护与该客户的交易。看来我至少有两个选择:将数据复制到必要的模型中,有效地对我的数据模型进行非规范化,这样删除的记录就不会影响相关数据。覆盖ActiveRecord的“销毁”行为以执行某些操作,例如设置一个标志指示用户“删除”了记录并使用此标志隐藏记录。我是否缺少更好的方法?选项1对我来说似乎是一个可怕的想法,但我很想听到相反的论据。选项2似乎有点像Rails,但我想知道

ruby - 如何测量 cucumber 步骤的执行时间

我正在寻找一种方法来衡量我的cucumber步骤的执行时间。使用junit格式,我设法获得了一些有关功能和场景执行时间的数据,但我还想查看场景中步骤的时间。 最佳答案 cucumber--formatusage“打印使用步骤定义的地方。首先列出最慢的步骤定义(带有持续时间)。” 关于ruby-如何测量cucumber步骤的执行时间,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7